<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.9.4"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>FFmpegKit iOS / macOS / tvOS API: AbstractSession.m Source File</title>
<link href="../../tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="../../jquery.js"></script>
<script type="text/javascript" src="../../dynsections.js"></script>
<link href="../../search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="../../search/searchdata.js"></script>
<script type="text/javascript" src="../../search/search.js"></script>
<link href="../../doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr id="projectrow">
  <td id="projectlogo"><img alt="Logo" src="../../ffmpeg-kit-icon-v9-small.png"/></td>
  <td id="projectalign">
   <div id="projectname">FFmpegKit iOS / macOS / tvOS API<span id="projectnumber">&#160;5.1</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.9.4 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "../../search",'Search','.html');
/* @license-end */
</script>
<script type="text/javascript" src="../../menudata.js"></script>
<script type="text/javascript" src="../../menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
  initMenu('../../',true,false,'search.php','Search');
  $(document).ready(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
</div><!-- top -->
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle"><div class="title">AbstractSession.m</div></div>
</div><!--header-->
<div class="contents">
<a href="../../d7/d96/_abstract_session_8m.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno">    1</span><span class="comment">/*</span></div>
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno">    2</span><span class="comment"> * Copyright (c) 2021-2022 Taner Sener</span></div>
<div class="line"><a id="l00003" name="l00003"></a><span class="lineno">    3</span><span class="comment"> *</span></div>
<div class="line"><a id="l00004" name="l00004"></a><span class="lineno">    4</span><span class="comment"> * This file is part of FFmpegKit.</span></div>
<div class="line"><a id="l00005" name="l00005"></a><span class="lineno">    5</span><span class="comment"> *</span></div>
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno">    6</span><span class="comment"> * FFmpegKit is free software: you can redistribute it and/or modify</span></div>
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno">    7</span><span class="comment"> * it under the terms of the GNU Lesser General License as published by</span></div>
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno">    8</span><span class="comment"> * the Free Software Foundation, either version 3 of the License, or</span></div>
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno">    9</span><span class="comment"> * (at your option) any later version.</span></div>
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno">   10</span><span class="comment"> *</span></div>
<div class="line"><a id="l00011" name="l00011"></a><span class="lineno">   11</span><span class="comment"> * FFmpegKit is distributed in the hope that it will be useful,</span></div>
<div class="line"><a id="l00012" name="l00012"></a><span class="lineno">   12</span><span class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</span></div>
<div class="line"><a id="l00013" name="l00013"></a><span class="lineno">   13</span><span class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the</span></div>
<div class="line"><a id="l00014" name="l00014"></a><span class="lineno">   14</span><span class="comment"> * GNU Lesser General License for more details.</span></div>
<div class="line"><a id="l00015" name="l00015"></a><span class="lineno">   15</span><span class="comment"> *</span></div>
<div class="line"><a id="l00016" name="l00016"></a><span class="lineno">   16</span><span class="comment"> *  You should have received a copy of the GNU Lesser General License</span></div>
<div class="line"><a id="l00017" name="l00017"></a><span class="lineno">   17</span><span class="comment"> *  along with FFmpegKit.  If not, see &lt;http://www.gnu.org/licenses/&gt;.</span></div>
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno">   18</span><span class="comment"> */</span></div>
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno">   19</span> </div>
<div class="line"><a id="l00020" name="l00020"></a><span class="lineno">   20</span><span class="preprocessor">#import &quot;<a class="code" href="../../d9/d76/_abstract_session_8h.html">AbstractSession.h</a>&quot;</span></div>
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno">   21</span><span class="preprocessor">#import &quot;<a class="code" href="../../d0/d7b/_atomic_long_8h.html">AtomicLong.h</a>&quot;</span></div>
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno">   22</span><span class="preprocessor">#import &quot;<a class="code" href="../../df/d99/_f_fmpeg_kit_8h.html">FFmpegKit.h</a>&quot;</span></div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno">   23</span><span class="preprocessor">#import &quot;<a class="code" href="../../df/d48/_f_fmpeg_kit_config_8h.html">FFmpegKitConfig.h</a>&quot;</span></div>
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno">   24</span><span class="preprocessor">#import &quot;<a class="code" href="../../d4/daf/_log_callback_8h.html">LogCallback.h</a>&quot;</span></div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno">   25</span><span class="preprocessor">#import &quot;<a class="code" href="../../d0/d19/_return_code_8h.html">ReturnCode.h</a>&quot;</span></div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno">   26</span> </div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="../../d9/d76/_abstract_session_8h.html#a77c3cbadb39e57da125bb8de5b92ed14">   27</a></span><span class="keywordtype">int</span> <span class="keyword">const</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a77c3cbadb39e57da125bb8de5b92ed14">AbstractSessionDefaultTimeoutForAsynchronousMessagesInTransmit</a> = 5000;</div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno">   28</span> </div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a81e286d01e53059770bc18436ece0521">   29</a></span><span class="keyword">static</span> <a class="code hl_class" href="../../db/d7d/interface_atomic_long.html">AtomicLong</a> *<a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a81e286d01e53059770bc18436ece0521">sessionIdGenerator</a> = nil;</div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno">   30</span> </div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno">   31</span><span class="keyword">extern</span> <span class="keywordtype">void</span> <a class="code hl_function" href="../../d7/d96/_abstract_session_8m.html#af0e9e0f2db88aec9594c3c9db76e0dc1">addSessionToSessionHistory</a>(id&lt;Session&gt; session);</div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno">   32</span> </div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno">   33</span><span class="keyword">@implementation </span><a class="code hl_class" href="../../db/de2/interface_abstract_session.html">AbstractSession</a> {</div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno">   34</span>    <span class="keywordtype">long</span> <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a>;</div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#aeb38e424308cfaa204bfceada3eb8b7b">   35</a></span>    <a class="code hl_typedef" href="../../d4/daf/_log_callback_8h.html#a85ffce44df85447234279b01b028ddd0">LogCallback</a> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#aeb38e424308cfaa204bfceada3eb8b7b">_logCallback</a>;</div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a78ff4cefa9f7c8d66dbbe804df6bde43">   36</a></span>    NSDate* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a78ff4cefa9f7c8d66dbbe804df6bde43">_createTime</a>;</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">   37</a></span>    NSDate* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a>;</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">   38</a></span>    NSDate* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a>;</div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a5101759b23bd0aca1eba5881d8fa1120">   39</a></span>    NSArray* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a5101759b23bd0aca1eba5881d8fa1120">_arguments</a>;</div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#aebe5db86a6bb97076929602e2c7bf761">   40</a></span>    NSMutableArray* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#aebe5db86a6bb97076929602e2c7bf761">_logs</a>;</div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a434c04c5f38286f4a60a6b731afb3540">   41</a></span>    NSRecursiveLock* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a434c04c5f38286f4a60a6b731afb3540">_logsLock</a>;</div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">   42</a></span>    SessionState <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a>;</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">   43</a></span>    <a class="code hl_class" href="../../db/d76/interface_return_code.html">ReturnCode</a>* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">_returnCode</a>;</div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">   44</a></span>    NSString* <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">_failStackTrace</a>;</div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="../../db/de2/interface_abstract_session.html#a3e673629123b8e7dafe0f908585dcea3">   45</a></span>    LogRedirectionStrategy <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a6c9bf74dc118bba50b188165b78fb5e4">_logRedirectionStrategy</a>;</div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno">   46</span>}</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno">   47</span> </div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno">   48</span>+ (void)initialize {</div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno">   49</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a81e286d01e53059770bc18436ece0521">sessionIdGenerator</a> = [[<a class="code hl_class" href="../../db/d7d/interface_atomic_long.html">AtomicLong</a> alloc] initWithValue:1];</div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno">   50</span>}</div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno">   51</span> </div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno">   52</span>- (instancetype)init:(NSArray*)arguments withLogCallback:(<a class="code hl_typedef" href="../../d4/daf/_log_callback_8h.html#a85ffce44df85447234279b01b028ddd0">LogCallback</a>)logCallback withLogRedirectionStrategy:(LogRedirectionStrategy)logRedirectionStrategy {</div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno">   53</span>    <span class="keyword">self</span> = [<span class="keyword">super</span> init];</div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno">   54</span>    <span class="keywordflow">if</span> (<span class="keyword">self</span>) {</div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno">   55</span>        <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a> = [sessionIdGenerator <a class="code hl_function" href="../../db/d7d/interface_atomic_long.html#acd84b0ea5397104ae62dd06321367adb">getAndIncrement</a>];</div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno">   56</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#aeb38e424308cfaa204bfceada3eb8b7b">_logCallback</a> = <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a612f601ca5618ac2fbcc417089173854">logCallback</a>;</div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno">   57</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a78ff4cefa9f7c8d66dbbe804df6bde43">_createTime</a> = [NSDate date];</div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno">   58</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a> = nil;</div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno">   59</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a> = nil;</div>
<div class="line"><a id="l00060" name="l00060"></a><span class="lineno">   60</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a5101759b23bd0aca1eba5881d8fa1120">_arguments</a> = arguments;</div>
<div class="line"><a id="l00061" name="l00061"></a><span class="lineno">   61</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#aebe5db86a6bb97076929602e2c7bf761">_logs</a> = [[NSMutableArray alloc] init];</div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno">   62</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a434c04c5f38286f4a60a6b731afb3540">_logsLock</a> = [[NSRecursiveLock alloc] init];</div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno">   63</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a> = SessionStateCreated;</div>
<div class="line"><a id="l00064" name="l00064"></a><span class="lineno">   64</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">_returnCode</a> = nil;</div>
<div class="line"><a id="l00065" name="l00065"></a><span class="lineno">   65</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">_failStackTrace</a> = nil;</div>
<div class="line"><a id="l00066" name="l00066"></a><span class="lineno">   66</span>        <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a6c9bf74dc118bba50b188165b78fb5e4">_logRedirectionStrategy</a> = logRedirectionStrategy;</div>
<div class="line"><a id="l00067" name="l00067"></a><span class="lineno">   67</span> </div>
<div class="line"><a id="l00068" name="l00068"></a><span class="lineno">   68</span>        <a class="code hl_function" href="../../d7/d96/_abstract_session_8m.html#af0e9e0f2db88aec9594c3c9db76e0dc1">addSessionToSessionHistory</a>(<span class="keyword">self</span>);</div>
<div class="line"><a id="l00069" name="l00069"></a><span class="lineno">   69</span>    }</div>
<div class="line"><a id="l00070" name="l00070"></a><span class="lineno">   70</span> </div>
<div class="line"><a id="l00071" name="l00071"></a><span class="lineno">   71</span>    <span class="keywordflow">return</span> <span class="keyword">self</span>;</div>
<div class="line"><a id="l00072" name="l00072"></a><span class="lineno">   72</span>}</div>
<div class="line"><a id="l00073" name="l00073"></a><span class="lineno">   73</span> </div>
<div class="line"><a id="l00074" name="l00074"></a><span class="lineno">   74</span>- (<a class="code hl_typedef" href="../../d4/daf/_log_callback_8h.html#a85ffce44df85447234279b01b028ddd0">LogCallback</a>)getLogCallback {</div>
<div class="line"><a id="l00075" name="l00075"></a><span class="lineno">   75</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#aeb38e424308cfaa204bfceada3eb8b7b">_logCallback</a>;</div>
<div class="line"><a id="l00076" name="l00076"></a><span class="lineno">   76</span>}</div>
<div class="line"><a id="l00077" name="l00077"></a><span class="lineno">   77</span> </div>
<div class="line"><a id="l00078" name="l00078"></a><span class="lineno">   78</span>- (long)getSessionId {</div>
<div class="line"><a id="l00079" name="l00079"></a><span class="lineno">   79</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a>;</div>
<div class="line"><a id="l00080" name="l00080"></a><span class="lineno">   80</span>}</div>
<div class="line"><a id="l00081" name="l00081"></a><span class="lineno">   81</span> </div>
<div class="line"><a id="l00082" name="l00082"></a><span class="lineno">   82</span>- (NSDate*)getCreateTime {</div>
<div class="line"><a id="l00083" name="l00083"></a><span class="lineno">   83</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a78ff4cefa9f7c8d66dbbe804df6bde43">_createTime</a>;</div>
<div class="line"><a id="l00084" name="l00084"></a><span class="lineno">   84</span>}</div>
<div class="line"><a id="l00085" name="l00085"></a><span class="lineno">   85</span> </div>
<div class="line"><a id="l00086" name="l00086"></a><span class="lineno">   86</span>- (NSDate*)getStartTime {</div>
<div class="line"><a id="l00087" name="l00087"></a><span class="lineno">   87</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a>;</div>
<div class="line"><a id="l00088" name="l00088"></a><span class="lineno">   88</span>}</div>
<div class="line"><a id="l00089" name="l00089"></a><span class="lineno">   89</span> </div>
<div class="line"><a id="l00090" name="l00090"></a><span class="lineno">   90</span>- (NSDate*)getEndTime {</div>
<div class="line"><a id="l00091" name="l00091"></a><span class="lineno">   91</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a>;</div>
<div class="line"><a id="l00092" name="l00092"></a><span class="lineno">   92</span>}</div>
<div class="line"><a id="l00093" name="l00093"></a><span class="lineno">   93</span> </div>
<div class="line"><a id="l00094" name="l00094"></a><span class="lineno">   94</span>- (long)getDuration {</div>
<div class="line"><a id="l00095" name="l00095"></a><span class="lineno">   95</span>    NSDate* startTime = <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a>;</div>
<div class="line"><a id="l00096" name="l00096"></a><span class="lineno">   96</span>    NSDate* endTime = <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a>;</div>
<div class="line"><a id="l00097" name="l00097"></a><span class="lineno">   97</span>    <span class="keywordflow">if</span> (startTime != nil &amp;&amp; endTime != nil) {</div>
<div class="line"><a id="l00098" name="l00098"></a><span class="lineno">   98</span>        <span class="keywordflow">return</span> [[NSNumber numberWithDouble:([endTime timeIntervalSinceDate:startTime]*1000)] longValue];</div>
<div class="line"><a id="l00099" name="l00099"></a><span class="lineno">   99</span>    }</div>
<div class="line"><a id="l00100" name="l00100"></a><span class="lineno">  100</span>    </div>
<div class="line"><a id="l00101" name="l00101"></a><span class="lineno">  101</span>    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a id="l00102" name="l00102"></a><span class="lineno">  102</span>}</div>
<div class="line"><a id="l00103" name="l00103"></a><span class="lineno">  103</span> </div>
<div class="line"><a id="l00104" name="l00104"></a><span class="lineno">  104</span>- (NSArray*)getArguments {</div>
<div class="line"><a id="l00105" name="l00105"></a><span class="lineno">  105</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a5101759b23bd0aca1eba5881d8fa1120">_arguments</a>;</div>
<div class="line"><a id="l00106" name="l00106"></a><span class="lineno">  106</span>}</div>
<div class="line"><a id="l00107" name="l00107"></a><span class="lineno">  107</span> </div>
<div class="line"><a id="l00108" name="l00108"></a><span class="lineno">  108</span>- (NSString*)getCommand {</div>
<div class="line"><a id="l00109" name="l00109"></a><span class="lineno">  109</span>    <span class="keywordflow">return</span> [<a class="code hl_class" href="../../de/d5f/interface_f_fmpeg_kit_config.html">FFmpegKitConfig</a> <a class="code hl_function" href="../../de/d5f/interface_f_fmpeg_kit_config.html#af20c5f0b22f67e5aab27114a3aa8f79b">argumentsToString</a>:_arguments];</div>
<div class="line"><a id="l00110" name="l00110"></a><span class="lineno">  110</span>}</div>
<div class="line"><a id="l00111" name="l00111"></a><span class="lineno">  111</span> </div>
<div class="line"><a id="l00112" name="l00112"></a><span class="lineno">  112</span>- (void)waitForAsynchronousMessagesInTransmit:(<span class="keywordtype">int</span>)timeout {</div>
<div class="line"><a id="l00113" name="l00113"></a><span class="lineno">  113</span>    NSDate* expireDate = [[NSDate date] dateByAddingTimeInterval:((double)timeout)/1000];</div>
<div class="line"><a id="l00114" name="l00114"></a><span class="lineno">  114</span>    dispatch_semaphore_t <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#aa91ec0f91afe80906264eb5dcec1bc9f">semaphore</a> = dispatch_semaphore_create(0);</div>
<div class="line"><a id="l00115" name="l00115"></a><span class="lineno">  115</span> </div>
<div class="line"><a id="l00116" name="l00116"></a><span class="lineno">  116</span>    <span class="keywordflow">while</span> ([<span class="keyword">self</span> thereAreAsynchronousMessagesInTransmit] &amp;&amp; ([[NSDate date] timeIntervalSinceDate:expireDate] &lt; 0)) {</div>
<div class="line"><a id="l00117" name="l00117"></a><span class="lineno">  117</span>        dispatch_semaphore_wait(<a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#aa91ec0f91afe80906264eb5dcec1bc9f">semaphore</a>, dispatch_time(DISPATCH_TIME_NOW, 100 * NSEC_PER_MSEC));</div>
<div class="line"><a id="l00118" name="l00118"></a><span class="lineno">  118</span>    }</div>
<div class="line"><a id="l00119" name="l00119"></a><span class="lineno">  119</span>}</div>
<div class="line"><a id="l00120" name="l00120"></a><span class="lineno">  120</span> </div>
<div class="line"><a id="l00121" name="l00121"></a><span class="lineno">  121</span>- (NSArray*)getAllLogsWithTimeout:(<span class="keywordtype">int</span>)waitTimeout {</div>
<div class="line"><a id="l00122" name="l00122"></a><span class="lineno">  122</span>    [<span class="keyword">self</span> waitForAsynchronousMessagesInTransmit:waitTimeout];</div>
<div class="line"><a id="l00123" name="l00123"></a><span class="lineno">  123</span> </div>
<div class="line"><a id="l00124" name="l00124"></a><span class="lineno">  124</span>    <span class="keywordflow">if</span> ([<span class="keyword">self</span> thereAreAsynchronousMessagesInTransmit]) {</div>
<div class="line"><a id="l00125" name="l00125"></a><span class="lineno">  125</span>        NSLog(<span class="stringliteral">@&quot;getAllLogsWithTimeout was called to return all logs but there are still logs being transmitted for session id %ld.&quot;</span>, <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a>);</div>
<div class="line"><a id="l00126" name="l00126"></a><span class="lineno">  126</span>    }</div>
<div class="line"><a id="l00127" name="l00127"></a><span class="lineno">  127</span> </div>
<div class="line"><a id="l00128" name="l00128"></a><span class="lineno">  128</span>    <span class="keywordflow">return</span> [<span class="keyword">self</span> getLogs];</div>
<div class="line"><a id="l00129" name="l00129"></a><span class="lineno">  129</span>}</div>
<div class="line"><a id="l00130" name="l00130"></a><span class="lineno">  130</span> </div>
<div class="line"><a id="l00131" name="l00131"></a><span class="lineno">  131</span>- (NSArray*)getAllLogs {</div>
<div class="line"><a id="l00132" name="l00132"></a><span class="lineno">  132</span>    <span class="keywordflow">return</span> [<span class="keyword">self</span> getAllLogsWithTimeout:AbstractSessionDefaultTimeoutForAsynchronousMessagesInTransmit];</div>
<div class="line"><a id="l00133" name="l00133"></a><span class="lineno">  133</span>}</div>
<div class="line"><a id="l00134" name="l00134"></a><span class="lineno">  134</span> </div>
<div class="line"><a id="l00135" name="l00135"></a><span class="lineno">  135</span>- (NSArray*)getLogs {</div>
<div class="line"><a id="l00136" name="l00136"></a><span class="lineno">  136</span>    [_logsLock lock];</div>
<div class="line"><a id="l00137" name="l00137"></a><span class="lineno">  137</span>    NSArray* logsCopy = [_logs copy];</div>
<div class="line"><a id="l00138" name="l00138"></a><span class="lineno">  138</span>    [_logsLock unlock];</div>
<div class="line"><a id="l00139" name="l00139"></a><span class="lineno">  139</span>    </div>
<div class="line"><a id="l00140" name="l00140"></a><span class="lineno">  140</span>    <span class="keywordflow">return</span> logsCopy;</div>
<div class="line"><a id="l00141" name="l00141"></a><span class="lineno">  141</span>}</div>
<div class="line"><a id="l00142" name="l00142"></a><span class="lineno">  142</span> </div>
<div class="line"><a id="l00143" name="l00143"></a><span class="lineno">  143</span>- (NSString*)getAllLogsAsStringWithTimeout:(<span class="keywordtype">int</span>)waitTimeout {</div>
<div class="line"><a id="l00144" name="l00144"></a><span class="lineno">  144</span>    [<span class="keyword">self</span> waitForAsynchronousMessagesInTransmit:waitTimeout];</div>
<div class="line"><a id="l00145" name="l00145"></a><span class="lineno">  145</span> </div>
<div class="line"><a id="l00146" name="l00146"></a><span class="lineno">  146</span>    <span class="keywordflow">if</span> ([<span class="keyword">self</span> thereAreAsynchronousMessagesInTransmit]) {</div>
<div class="line"><a id="l00147" name="l00147"></a><span class="lineno">  147</span>        NSLog(<span class="stringliteral">@&quot;getAllLogsAsStringWithTimeout was called to return all logs but there are still logs being transmitted for session id %ld.&quot;</span>, <a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a>);</div>
<div class="line"><a id="l00148" name="l00148"></a><span class="lineno">  148</span>    }</div>
<div class="line"><a id="l00149" name="l00149"></a><span class="lineno">  149</span> </div>
<div class="line"><a id="l00150" name="l00150"></a><span class="lineno">  150</span>    <span class="keywordflow">return</span> [<span class="keyword">self</span> getLogsAsString];</div>
<div class="line"><a id="l00151" name="l00151"></a><span class="lineno">  151</span>}</div>
<div class="line"><a id="l00152" name="l00152"></a><span class="lineno">  152</span> </div>
<div class="line"><a id="l00153" name="l00153"></a><span class="lineno">  153</span>- (NSString*)getAllLogsAsString {</div>
<div class="line"><a id="l00154" name="l00154"></a><span class="lineno">  154</span>    <span class="keywordflow">return</span> [<span class="keyword">self</span> getAllLogsAsStringWithTimeout:AbstractSessionDefaultTimeoutForAsynchronousMessagesInTransmit];</div>
<div class="line"><a id="l00155" name="l00155"></a><span class="lineno">  155</span>}</div>
<div class="line"><a id="l00156" name="l00156"></a><span class="lineno">  156</span> </div>
<div class="line"><a id="l00157" name="l00157"></a><span class="lineno">  157</span>- (NSString*)getLogsAsString {</div>
<div class="line"><a id="l00158" name="l00158"></a><span class="lineno">  158</span>    NSMutableString* concatenatedString = [[NSMutableString alloc] init];</div>
<div class="line"><a id="l00159" name="l00159"></a><span class="lineno">  159</span> </div>
<div class="line"><a id="l00160" name="l00160"></a><span class="lineno">  160</span>    [_logsLock lock];</div>
<div class="line"><a id="l00161" name="l00161"></a><span class="lineno">  161</span>    <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i=0; i &lt; [_logs count]; i++) {</div>
<div class="line"><a id="l00162" name="l00162"></a><span class="lineno">  162</span>        [concatenatedString appendString:[[_logs objectAtIndex:i] getMessage]];</div>
<div class="line"><a id="l00163" name="l00163"></a><span class="lineno">  163</span>    }</div>
<div class="line"><a id="l00164" name="l00164"></a><span class="lineno">  164</span>    [_logsLock unlock];</div>
<div class="line"><a id="l00165" name="l00165"></a><span class="lineno">  165</span> </div>
<div class="line"><a id="l00166" name="l00166"></a><span class="lineno">  166</span>    <span class="keywordflow">return</span> concatenatedString;</div>
<div class="line"><a id="l00167" name="l00167"></a><span class="lineno">  167</span>}</div>
<div class="line"><a id="l00168" name="l00168"></a><span class="lineno">  168</span> </div>
<div class="line"><a id="l00169" name="l00169"></a><span class="lineno">  169</span>- (NSString*)getOutput {</div>
<div class="line"><a id="l00170" name="l00170"></a><span class="lineno">  170</span>    <span class="keywordflow">return</span> [<span class="keyword">self</span> getAllLogsAsString];</div>
<div class="line"><a id="l00171" name="l00171"></a><span class="lineno">  171</span>}</div>
<div class="line"><a id="l00172" name="l00172"></a><span class="lineno">  172</span> </div>
<div class="line"><a id="l00173" name="l00173"></a><span class="lineno">  173</span>- (SessionState)getState {</div>
<div class="line"><a id="l00174" name="l00174"></a><span class="lineno">  174</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a>;</div>
<div class="line"><a id="l00175" name="l00175"></a><span class="lineno">  175</span>}</div>
<div class="line"><a id="l00176" name="l00176"></a><span class="lineno">  176</span> </div>
<div class="line"><a id="l00177" name="l00177"></a><span class="lineno">  177</span>- (<a class="code hl_class" href="../../db/d76/interface_return_code.html">ReturnCode</a>*)getReturnCode {</div>
<div class="line"><a id="l00178" name="l00178"></a><span class="lineno">  178</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">_returnCode</a>;</div>
<div class="line"><a id="l00179" name="l00179"></a><span class="lineno">  179</span>}</div>
<div class="line"><a id="l00180" name="l00180"></a><span class="lineno">  180</span> </div>
<div class="line"><a id="l00181" name="l00181"></a><span class="lineno">  181</span>- (NSString*)getFailStackTrace {</div>
<div class="line"><a id="l00182" name="l00182"></a><span class="lineno">  182</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">_failStackTrace</a>;</div>
<div class="line"><a id="l00183" name="l00183"></a><span class="lineno">  183</span>}</div>
<div class="line"><a id="l00184" name="l00184"></a><span class="lineno">  184</span> </div>
<div class="line"><a id="l00185" name="l00185"></a><span class="lineno">  185</span>- (LogRedirectionStrategy)getLogRedirectionStrategy {</div>
<div class="line"><a id="l00186" name="l00186"></a><span class="lineno">  186</span>    <span class="keywordflow">return</span> <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a6c9bf74dc118bba50b188165b78fb5e4">_logRedirectionStrategy</a>;</div>
<div class="line"><a id="l00187" name="l00187"></a><span class="lineno">  187</span>}</div>
<div class="line"><a id="l00188" name="l00188"></a><span class="lineno">  188</span> </div>
<div class="line"><a id="l00189" name="l00189"></a><span class="lineno">  189</span>- (BOOL)thereAreAsynchronousMessagesInTransmit {</div>
<div class="line"><a id="l00190" name="l00190"></a><span class="lineno">  190</span>    <span class="keywordflow">return</span> ([<a class="code hl_class" href="../../de/d5f/interface_f_fmpeg_kit_config.html">FFmpegKitConfig</a> messagesInTransmit:<a class="code hl_variable" href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a>] != 0);</div>
<div class="line"><a id="l00191" name="l00191"></a><span class="lineno">  191</span>}</div>
<div class="line"><a id="l00192" name="l00192"></a><span class="lineno">  192</span> </div>
<div class="line"><a id="l00193" name="l00193"></a><span class="lineno">  193</span>- (void)addLog:(<a class="code hl_class" href="../../d2/d1c/interface_log.html">Log</a>*)log {</div>
<div class="line"><a id="l00194" name="l00194"></a><span class="lineno">  194</span>    [_logsLock lock];</div>
<div class="line"><a id="l00195" name="l00195"></a><span class="lineno">  195</span>    [_logs addObject:log];</div>
<div class="line"><a id="l00196" name="l00196"></a><span class="lineno">  196</span>    [_logsLock unlock];</div>
<div class="line"><a id="l00197" name="l00197"></a><span class="lineno">  197</span>}</div>
<div class="line"><a id="l00198" name="l00198"></a><span class="lineno">  198</span> </div>
<div class="line"><a id="l00199" name="l00199"></a><span class="lineno">  199</span>- (void)startRunning {</div>
<div class="line"><a id="l00200" name="l00200"></a><span class="lineno">  200</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a> = SessionStateRunning;</div>
<div class="line"><a id="l00201" name="l00201"></a><span class="lineno">  201</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a> = [NSDate date];</div>
<div class="line"><a id="l00202" name="l00202"></a><span class="lineno">  202</span>}</div>
<div class="line"><a id="l00203" name="l00203"></a><span class="lineno">  203</span> </div>
<div class="line"><a id="l00204" name="l00204"></a><span class="lineno">  204</span>- (void)complete:(<a class="code hl_class" href="../../db/d76/interface_return_code.html">ReturnCode</a>*)returnCode {</div>
<div class="line"><a id="l00205" name="l00205"></a><span class="lineno">  205</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">_returnCode</a> = returnCode;</div>
<div class="line"><a id="l00206" name="l00206"></a><span class="lineno">  206</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a> = SessionStateCompleted;</div>
<div class="line"><a id="l00207" name="l00207"></a><span class="lineno">  207</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a> = [NSDate date];</div>
<div class="line"><a id="l00208" name="l00208"></a><span class="lineno">  208</span>}</div>
<div class="line"><a id="l00209" name="l00209"></a><span class="lineno">  209</span> </div>
<div class="line"><a id="l00210" name="l00210"></a><span class="lineno">  210</span>- (void)fail:(NSException*)exception {</div>
<div class="line"><a id="l00211" name="l00211"></a><span class="lineno">  211</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">_failStackTrace</a> = [NSString stringWithFormat:@&quot;%@\n%@&quot;, [exception userInfo], [exception callStackSymbols]];</div>
<div class="line"><a id="l00212" name="l00212"></a><span class="lineno">  212</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a> = SessionStateFailed;</div>
<div class="line"><a id="l00213" name="l00213"></a><span class="lineno">  213</span>    <a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a> = [NSDate date];</div>
<div class="line"><a id="l00214" name="l00214"></a><span class="lineno">  214</span>}</div>
<div class="line"><a id="l00215" name="l00215"></a><span class="lineno">  215</span> </div>
<div class="line"><a id="l00216" name="l00216"></a><span class="lineno">  216</span>- (BOOL)isFFmpeg {</div>
<div class="line"><a id="l00217" name="l00217"></a><span class="lineno">  217</span>    <span class="comment">// IMPLEMENTED IN SUBCLASSES</span></div>
<div class="line"><a id="l00218" name="l00218"></a><span class="lineno">  218</span>    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
<div class="line"><a id="l00219" name="l00219"></a><span class="lineno">  219</span>}</div>
<div class="line"><a id="l00220" name="l00220"></a><span class="lineno">  220</span> </div>
<div class="line"><a id="l00221" name="l00221"></a><span class="lineno">  221</span>- (BOOL)isFFprobe {</div>
<div class="line"><a id="l00222" name="l00222"></a><span class="lineno">  222</span>    <span class="comment">// IMPLEMENTED IN SUBCLASSES</span></div>
<div class="line"><a id="l00223" name="l00223"></a><span class="lineno">  223</span>    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
<div class="line"><a id="l00224" name="l00224"></a><span class="lineno">  224</span>}</div>
<div class="line"><a id="l00225" name="l00225"></a><span class="lineno">  225</span> </div>
<div class="line"><a id="l00226" name="l00226"></a><span class="lineno">  226</span>- (BOOL)isMediaInformation {</div>
<div class="line"><a id="l00227" name="l00227"></a><span class="lineno">  227</span>    <span class="comment">// IMPLEMENTED IN SUBCLASSES</span></div>
<div class="line"><a id="l00228" name="l00228"></a><span class="lineno">  228</span>    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
<div class="line"><a id="l00229" name="l00229"></a><span class="lineno">  229</span>}</div>
<div class="line"><a id="l00230" name="l00230"></a><span class="lineno">  230</span> </div>
<div class="line"><a id="l00231" name="l00231"></a><span class="lineno">  231</span>- (void)cancel {</div>
<div class="line"><a id="l00232" name="l00232"></a><span class="lineno">  232</span>    <span class="keywordflow">if</span> (<a class="code hl_variable" href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a> == SessionStateRunning) {</div>
<div class="line"><a id="l00233" name="l00233"></a><span class="lineno">  233</span>        [<a class="code hl_class" href="../../d2/d0b/interface_f_fmpeg_kit.html">FFmpegKit</a> <a class="code hl_function" href="../../d2/d0b/interface_f_fmpeg_kit.html#a7dd3f87609bb5679b4b33a87cb88c386">cancel</a>:_sessionId];</div>
<div class="line"><a id="l00234" name="l00234"></a><span class="lineno">  234</span>    }</div>
<div class="line"><a id="l00235" name="l00235"></a><span class="lineno">  235</span>}</div>
<div class="line"><a id="l00236" name="l00236"></a><span class="lineno">  236</span> </div>
<div class="line"><a id="l00237" name="l00237"></a><span class="lineno">  237</span><span class="keyword">@end</span></div>
<div class="ttc" id="a_abstract_session_8h_html"><div class="ttname"><a href="../../d9/d76/_abstract_session_8h.html">AbstractSession.h</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a23ab142fb163fe7ad9d77d90aeb9e7bf"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a23ab142fb163fe7ad9d77d90aeb9e7bf">_failStackTrace</a></div><div class="ttdeci">NSString * _failStackTrace</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00044">AbstractSession.m:44</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a434c04c5f38286f4a60a6b731afb3540"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a434c04c5f38286f4a60a6b731afb3540">_logsLock</a></div><div class="ttdeci">NSRecursiveLock * _logsLock</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00041">AbstractSession.m:41</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a471a674643c1d9f5e37ecddb8aad3dff"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a471a674643c1d9f5e37ecddb8aad3dff">_endTime</a></div><div class="ttdeci">NSDate * _endTime</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00038">AbstractSession.m:38</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a5101759b23bd0aca1eba5881d8fa1120"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a5101759b23bd0aca1eba5881d8fa1120">_arguments</a></div><div class="ttdeci">NSArray * _arguments</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00039">AbstractSession.m:39</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a660836bbdf4d71485d78c79d083879d3"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a660836bbdf4d71485d78c79d083879d3">_state</a></div><div class="ttdeci">SessionState _state</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00042">AbstractSession.m:42</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a6c9bf74dc118bba50b188165b78fb5e4"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a6c9bf74dc118bba50b188165b78fb5e4">_logRedirectionStrategy</a></div><div class="ttdeci">LogRedirectionStrategy _logRedirectionStrategy</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00045">AbstractSession.m:45</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a76546c94740259e8b0d3e33394adf8f1"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a76546c94740259e8b0d3e33394adf8f1">_startTime</a></div><div class="ttdeci">NSDate * _startTime</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00037">AbstractSession.m:37</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a77c3cbadb39e57da125bb8de5b92ed14"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a77c3cbadb39e57da125bb8de5b92ed14">AbstractSessionDefaultTimeoutForAsynchronousMessagesInTransmit</a></div><div class="ttdeci">int const AbstractSessionDefaultTimeoutForAsynchronousMessagesInTransmit</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00027">AbstractSession.m:27</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a78ff4cefa9f7c8d66dbbe804df6bde43"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a78ff4cefa9f7c8d66dbbe804df6bde43">_createTime</a></div><div class="ttdeci">NSDate * _createTime</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00036">AbstractSession.m:36</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a81e286d01e53059770bc18436ece0521"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a81e286d01e53059770bc18436ece0521">sessionIdGenerator</a></div><div class="ttdeci">static AtomicLong * sessionIdGenerator</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00029">AbstractSession.m:29</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_a870ab4e0064d1626b3256b41f2d022b6"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#a870ab4e0064d1626b3256b41f2d022b6">_returnCode</a></div><div class="ttdeci">ReturnCode * _returnCode</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00043">AbstractSession.m:43</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_aeb38e424308cfaa204bfceada3eb8b7b"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#aeb38e424308cfaa204bfceada3eb8b7b">_logCallback</a></div><div class="ttdeci">LogCallback _logCallback</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00035">AbstractSession.m:35</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_aebe5db86a6bb97076929602e2c7bf761"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#aebe5db86a6bb97076929602e2c7bf761">_logs</a></div><div class="ttdeci">NSMutableArray * _logs</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d96/_abstract_session_8m_source.html#l00040">AbstractSession.m:40</a></div></div>
<div class="ttc" id="a_abstract_session_8m_html_af0e9e0f2db88aec9594c3c9db76e0dc1"><div class="ttname"><a href="../../d7/d96/_abstract_session_8m.html#af0e9e0f2db88aec9594c3c9db76e0dc1">addSessionToSessionHistory</a></div><div class="ttdeci">void addSessionToSessionHistory(id&lt; Session &gt; session)</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d9e/_f_fmpeg_kit_config_8m_source.html#l00117">FFmpegKitConfig.m:117</a></div></div>
<div class="ttc" id="a_atomic_long_8h_html"><div class="ttname"><a href="../../d0/d7b/_atomic_long_8h.html">AtomicLong.h</a></div></div>
<div class="ttc" id="a_f_fmpeg_kit_8h_html"><div class="ttname"><a href="../../df/d99/_f_fmpeg_kit_8h.html">FFmpegKit.h</a></div></div>
<div class="ttc" id="a_f_fmpeg_kit_config_8h_html"><div class="ttname"><a href="../../df/d48/_f_fmpeg_kit_config_8h.html">FFmpegKitConfig.h</a></div></div>
<div class="ttc" id="a_f_fmpeg_kit_config_8m_html_a612f601ca5618ac2fbcc417089173854"><div class="ttname"><a href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a612f601ca5618ac2fbcc417089173854">logCallback</a></div><div class="ttdeci">static LogCallback logCallback</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d9e/_f_fmpeg_kit_config_8m_source.html#l00065">FFmpegKitConfig.m:65</a></div></div>
<div class="ttc" id="a_f_fmpeg_kit_config_8m_html_a74c8a5fb2ae49f1c986bdfe1ddb96f53"><div class="ttname"><a href="../../da/d9e/_f_fmpeg_kit_config_8m.html#a74c8a5fb2ae49f1c986bdfe1ddb96f53">_sessionId</a></div><div class="ttdeci">long _sessionId</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d9e/_f_fmpeg_kit_config_8m_source.html#l00144">FFmpegKitConfig.m:144</a></div></div>
<div class="ttc" id="a_f_fmpeg_kit_config_8m_html_aa91ec0f91afe80906264eb5dcec1bc9f"><div class="ttname"><a href="../../da/d9e/_f_fmpeg_kit_config_8m.html#aa91ec0f91afe80906264eb5dcec1bc9f">semaphore</a></div><div class="ttdeci">static dispatch_semaphore_t semaphore</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d9e/_f_fmpeg_kit_config_8m_source.html#l00080">FFmpegKitConfig.m:80</a></div></div>
<div class="ttc" id="a_log_callback_8h_html"><div class="ttname"><a href="../../d4/daf/_log_callback_8h.html">LogCallback.h</a></div></div>
<div class="ttc" id="a_log_callback_8h_html_a85ffce44df85447234279b01b028ddd0"><div class="ttname"><a href="../../d4/daf/_log_callback_8h.html#a85ffce44df85447234279b01b028ddd0">LogCallback</a></div><div class="ttdeci">void(^ LogCallback)(Log *log)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/daf/_log_callback_8h_source.html#l00031">LogCallback.h:31</a></div></div>
<div class="ttc" id="a_return_code_8h_html"><div class="ttname"><a href="../../d0/d19/_return_code_8h.html">ReturnCode.h</a></div></div>
<div class="ttc" id="ainterface_abstract_session_html"><div class="ttname"><a href="../../db/de2/interface_abstract_session.html">AbstractSession</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d9/d76/_abstract_session_8h_source.html#l00035">AbstractSession.h:35</a></div></div>
<div class="ttc" id="ainterface_atomic_long_html"><div class="ttname"><a href="../../db/d7d/interface_atomic_long.html">AtomicLong</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d0/d7b/_atomic_long_8h_source.html#l00028">AtomicLong.h:29</a></div></div>
<div class="ttc" id="ainterface_atomic_long_html_acd84b0ea5397104ae62dd06321367adb"><div class="ttname"><a href="../../db/d7d/interface_atomic_long.html#acd84b0ea5397104ae62dd06321367adb">-[AtomicLong getAndIncrement]</a></div><div class="ttdeci">long getAndIncrement()</div><div class="ttdef"><b>Definition:</b> <a href="../../d0/d61/_atomic_long_8m_source.html#l00001">AtomicLong.m:40</a></div></div>
<div class="ttc" id="ainterface_f_fmpeg_kit_config_html"><div class="ttname"><a href="../../de/d5f/interface_f_fmpeg_kit_config.html">FFmpegKitConfig</a></div><div class="ttdef"><b>Definition:</b> <a href="../../df/d48/_f_fmpeg_kit_config_8h_source.html#l00048">FFmpegKitConfig.h:49</a></div></div>
<div class="ttc" id="ainterface_f_fmpeg_kit_config_html_af20c5f0b22f67e5aab27114a3aa8f79b"><div class="ttname"><a href="../../de/d5f/interface_f_fmpeg_kit_config.html#af20c5f0b22f67e5aab27114a3aa8f79b">+[FFmpegKitConfig argumentsToString:]</a></div><div class="ttdeci">NSString * argumentsToString:(NSArray *arguments)</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d9e/_f_fmpeg_kit_config_8m_source.html#l00155">FFmpegKitConfig.m:1385</a></div></div>
<div class="ttc" id="ainterface_f_fmpeg_kit_html"><div class="ttname"><a href="../../d2/d0b/interface_f_fmpeg_kit.html">FFmpegKit</a></div><div class="ttdef"><b>Definition:</b> <a href="../../df/d99/_f_fmpeg_kit_8h_source.html#l00043">FFmpegKit.h:44</a></div></div>
<div class="ttc" id="ainterface_f_fmpeg_kit_html_a7dd3f87609bb5679b4b33a87cb88c386"><div class="ttname"><a href="../../d2/d0b/interface_f_fmpeg_kit.html#a7dd3f87609bb5679b4b33a87cb88c386">+[FFmpegKit cancel:]</a></div><div class="ttdeci">void cancel:(long sessionId)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d53/_f_fmpeg_kit_8m_source.html#l00001">FFmpegKit.m:106</a></div></div>
<div class="ttc" id="ainterface_log_html"><div class="ttname"><a href="../../d2/d1c/interface_log.html">Log</a></div><div class="ttdef"><b>Definition:</b> <a href="../../da/df4/_log_8h_source.html#l00028">Log.h:29</a></div></div>
<div class="ttc" id="ainterface_return_code_html"><div class="ttname"><a href="../../db/d76/interface_return_code.html">ReturnCode</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d0/d19/_return_code_8h_source.html#l00030">ReturnCode.h:31</a></div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Sat Sep 17 2022 18:38:13 for FFmpegKit iOS / macOS / tvOS API by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="../../doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.4
</small></address>
</body>
</html>
